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(54) Satellite communications system utilizing parallel concatenated coding 



(57) A VSAT satellite communications network uti- 
lizes parallel concatenated coding (28,48) on its in- 
bound or outbound links (20,22), or both. For short data 
blocks, nonrecursive systematic tail-biting convolutional 
codes are used. For longer data blocks, recursive sys- 
tematic convolutional codes are used. These parallel 



concatenated coding techniques are used in conjunc- 
tion with spread-spectrum modulation (32,44) to provide 
a VSAT communications system which meets FCC reg- 
ulations on the total power spectral density of transmit- 
ted signals as well as mitigates interference from adja- 
cent satellites. 
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Description 

The present invention relates generally to satellite communications systems and, more particularly, to a very small 
aperture terminal satellite communications system employing parallel concatenated coding on its inbound or outbound 
5 links, or both. 

There is an emerging market for multi-media communications via satellite using low-cost, very small aperture 
terminals (VSAT's). Advantages of utilizing a smaller antenna than is currently the general practice in the industry today 
include a reduced reflector cost, lower shipping costs, reduced mounting hardware and labor, and greater customer 
acceptance due to a less obtrusive appearance. However, the use of a smaller-aperture dish antenna can cause an 

10 undesirable reduction in network capacity. This is due to several causes related to the reduced antenna size: (1 ) de- 
creased received and transmitted signal power caused by the associated decrease in antenna gain; and (2) Federal 
Communications Commission (FCC) regulations limiting the power transmitted by a VSAT utilizing an antenna smaller 
than a specified size in order to limit the interfering power flux density at adjacent satellite orbital slots. The use of a 
VSAT power amplifier with the same or less power output in order to reduce VSAT cost further contributes to the 

*5 decrease in network capacity due to power limitations. 

Unfortunately, it is difficult to obtain the desired large coding gain on short data blocks (that are typical of some 
types of VSAT transmissions) to solve these problems with the required bandwidth efficiency and decoder complexity 
using conventional coding techniques. 

Accordingly, it is desirable to provide a satellite communications system that increases network capacity when 

20 VSAT's with reduced antenna apertures are used by decreasing the required energy-per-bit-to-noise power-spectral- 
density ratio with spectrally efficient techniques. 

In accordance with the present invention, a VSAT satellite communications network utilizes parallel concatenated 
coding on its inbound or outbound links, or both. In one embodiment, for short data blocks that are typical of packet 
transmissions, credit card transactions, and compressed voice communications, nonrecursive systematic tail-biting 

25 convolutional codes are used as the component codes in such a parallel concatenated coding scheme. For longer 
data blocks that are typical of file transmission, the VSAT and network's hub terminal utilize recursive systematic con- 
volutional codes. 

In a preferred embodiment, the aforementioned parallel concatenated coding techniques are used in conjunction 
with spread-spectrum modulation, resulting in a system which meets FCC regulations on the total power spectral 
30 density of transmitted signals and mitigates interference from adjacent satellites. 

The features and advantages of the present invention will become apparent from the following detailed description 
of the invention when read with the accompanying drawings in which: 

FIG. 1 is a simplified block diagram illustrating a VSAT communications system employing parallel concatenated 
35 coding in accordance with the present invention; 

FIG. 2 is a simplified block diagram illustrating a VSAT satellite communications system's hub terminal employing 
parallel concatenated coding according to the present invention; 

40 FIG. 3 is a simplified block diagram illustrating a programmable encoder useful in a VSAT communications system 

according to the present invention; and 

FIG. 4 is a simplified block diagram illustrating a programmable decoder useful in a VSAT communications system 
according to the present invention. 

45 

The invention described herein is a VSAT satellite communications system utilizing parallel concatenated coding 
techniques involving, for example, parallel concatenated tail-biting convolutional codes and parallel concatenated re- 
cursive systematic convolutional codes (i.e., so-called "turbo codes"), and their respective decoders. In particular, for 
parallel concatenated tail-biting convolutional codes, a decoder comprising circular MAP decoding is employed, such 

50 as described in commonly assigned, copending U.S. Pat, Application No. 08/636,742 of Stephen M. Hladik and John 
B. Anderson, filed April 19, 1996 

Parallel concatenated coding is used on the inbound-link transmissions (VSAT-to-hub) or outbound-link transmis- 
sions (hub-to-VSAT) or both links of a VSAT satellite communications network. In addition, parallel concatenated coding 
can be utilized to provide error correction/detection coding for direct peer-to-peer (VSAT-to-VSAT) transmissions. In 

55 one embodiment, for short data blocks that are typical of packet transmissions, credit card transactions, and com- 
pressed voice communications, nonrecursive systematic tail-biting convolutional codes are used as the component 
codes in a parallel concatenated coding scheme. For longer data blocks that are typical of file transmission, parallel 
concatenated coding comprising recursive systematic convolutional codes is utilized by the VSAT's and the network's 
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hub terminal. 

In accordance with the present invention, the use of these parallel concatenated coding techniques in conjunction 
with spread-spectrum modulation provides a very effective solution to facilitate compliance with the aforementioned 
FCC regulations on adjacent satellite interference by decreasing the required effective radiated power (ERP) and the 
s power spectral density of the transmitted signal. In addition, this combination mitigates interference from adjacent 
satellites. 

FIG. 1 is a block diagram of a VSAT satellite communications system that employs parallel concatenated coding 
in accordance with the present invention. This system fundamentally comprises a number of VSAT terminals 10, a 
satellite 12 with a communications transponder, and possibly a hub terminal 14. Communication within the VSAT net- 

10 work may be either one-way or two-way and may travel in a variety of paths: (1) VSAT-to-VSAT directly (i.e., mesh 
connectivity) and (2) VSAT-to-hub-terminal and/or hub-terminal-to-VSAT (i.e., star connectivity). 

As shown in FIG. 1, a VSAT terminal 10 comprises transmitter signal processing 20, receiver signal processing 
22 and an antenna 24. In accordance with the invention described herein, the VSAT's transmitter signal processing 
comprises the following: an input port 25 for accepting data from an information source 26; an encoder 28 that applies 

15 a parallel concatenated code to blocks of data bits received from the source; a packet formatter 30 for generating a 
data packet (comprising one or more codewords from encoder 28), a synchronization bit pattern and control signaling 
bits; a modulator 32; an up-converter 34 for translating the modulated signal to the carrier frequency; a power amplifier 
36; and connection to antenna 24 via an appropriate interface (e.g., a switch or filter duplexer). The VSAT's receiver 
signal processing comprises: a low-noise amplifier 40, a down-converter 42 for translating the received signal from the 

20 carrier frequency to an intermediate frequency, a demodulator 44 for synchronization and demodulation, a packet-to- 
codeword formatter 46, a decoder 48 suitable for the parallel concatenated code utilized by the transmitter, and an 
output port 49 for transferring received messages (i.e., blocks of data bits) to an information sink 50. For brevity, a 
detailed block diagram is only shown for one VSAT in FIG. 1 . 

The synchronization functions performed by demodulator 44 include carrier frequency synchronization, frame syn- 

25 chronization, symbol synchronization, and, if needed, carrier phase synchronization. Symbol synchronization is the 
process of estimating the best sampling time (i.e., the symbol epoch) for the demodulator output in order to minimize 
the probability of a symbol decision error. Frame synchronization is the process of estimating the symbol epoch for the 
first symbol in a received data frame (for continuous transmissions) or packet (for discontinuous transmissions). 
For the case in which spread spectrum signals are transmitted by the VSAT, the VSAT modulator shown in FIG. 

30 1 includes the spreading function; and the VSAT demodulator shown in FIG. 1 includes the despreading function. 
Spread spectrum techniques increase the signal bandwidth relative to the bandwidth of the modulated data signal by 
imposing a spreading signal comprising chips (in the case of direct sequence spread spectrum) or hops (in the case 
of frequency hopping spread spectrum) that are pseudorandom and independent of the data signal. In direct sequence 
spread spectrum, the data signal is multiplied by a signal that corresponds to a pseudorandom sequence of chips 

35 having the values of +1 or -1. The duration of the chip pulses is less than the symbol interval of the modulated data 
signal; hence, the resulting signal's bandwidth is greater than that of the original modulated signal. In frequency hopping 
spread spectrum, the carrier frequency of the modulated signal is changed periodically according to a pseudorandom 
pattern. Again, the bandwidth of the spread signal is greater than that of the original modulated signal. 

Despreading in the demodulator is the process of removing the spreading from the received signal. Typically, the 

40 demodulator correlates the received signal with a replica of the spreading waveform to despread a direct sequence 
spread spectrum signal, while in a frequency hopping spread spectrum system, it hops the frequency of an oscillator 
in the receiver's down converter using the same pattern employed by the transmitting terminal to despread a frequency 
hopped spread spectrum signal. Typically, a filter is applied to the received signal after despreading to attenuate wide- 
band noise and interference components in the recovered signal. 

45 A block diagram of the hub terminal is presented in FIG. 2. In accordance with the invention described herein, it 

comprises: input ports 51 for accepting data from one or more information sources 52; output ports 53 for transferring 
received messages (i.e., blocks of data bits) to one or more information sinks 54; a bank of transmitter channel proc- 
essors 56; a bank of receiver channel processors 58; a switch 60 for connecting each active source to a transmitter 
channel processor and for connecting each active receiver channel processor to the appropriate information sink or a 

50 transmitter channel processor; a memory 62; a controller 64 for controlling the flow of data through the switch; a com- 
biner 66 for combining the signals generated by each transmitter channel processor into one signal; an up-converter 
68 for translating the combined signals to the carrier frequency; a power amplifier 70 connected to the antenna via an 
appropriate interface (e.g., a switch or filter duplexer); an antenna 72; a low-noise amplifier 74 that is coupled to the 
antenna via the aforementioned interface; a down -converter 76 for translating the received signal from the carrier 

55 frequency to an intermediate frequency (IF); and a signal splitter 78 for providing the IF received signal or possibly a 
filtered version of the IF received signal to the bank of receiver channel processors. 

The transmitter channel processor shown in FIG. 2 comprises: an encoder 80 that applies a parallel concatenated 
code to blocks of data bits received from a source; a packet formatter 82 for generating a data packet (comprising one 
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or more codewords from encoder 80), a synchronization bit pattern and control signaling bits; and a modulator 84. As 
with the VSAT, the hub's modulators include the spreading function for the case in which spread spectrum signals are 
transmitted by the hub. The receiver channel processor of FIG. 2 comprises a demodulator 86, a packet-to-codeword 
converter 88 for selecting samples from the demodulator output to form the' received codewords that are inputted to 
a decoder for parallel concatenated codes, and a decoder 90 suitable for the parallel concatenated code utilized by 
the transmitter. The hub's demodulators include several functions: synchronization, demodulation, and, for the case 
in which the hub receives spread spectrum signals, despreading. 

One function of the hub's memory is to temporarily store data received from the information sources or receiver 
channel processors in the event that all transmitter channel processors or output ports are busy when a message 
arrives at switch 60. The memory also stores necessary network configuration parameters and operational data. 

In one alternative embodiment of the present invention, an outer code is used in series concatenation with the 
(inner) parallel concatenated code (PCC); an associated outer decoder is also connected in series concatenation with 
the decoder for the inner PCC. 

Additionally, a flexible, programmable encoder/decoder system may be utilized by the VSAT and hub equipment 
for implementing several options: 

(1) parallel concatenated coding as described hereinabove; 

(2) an outer code in series concatenation with an inner parallel concatenated code (PCC) as described herein- 
above; 

(3) serial concatenated coding comprising an outer encoder and only one component encoder of a PCC encoder; 

(4) a conventional convolutional code or block code alone (i.e., without series or parallel concatenation). 

FIG. 3 illustrates a block diagram of a flexible, programmable encoder that implements these four coding options. 
As shown, the flexible, programmable encoder comprises an encoder 100 for parallel concatenated codes, an encoder 
102 for an outer code, and five switches S1-S5. Encoder 100 for parallel concatenated codes comprises N encoders, 
N-1 interleavers, and a codeword formatter 1 06. Table I as follows summarizes the switch positions for various modes 
of encoder operation. 



Table I 



Mode 


Switch Positions 




S1 


S2 


S3 


S4 


S5 


(1) PCCC 


0 


0 


CLOSED 


0 


0 


(2) Serial concatenation with inner PCC 


1 


1 


CLOSED 


0 


0 


(3) Standard serial concatenation 


1 


1 


OPEN 


1 


1 


(4) Single code 


0 


0 


OPEN 


1 


1 



FIG. 4 is a block diagram of a flexible, programmable decoder that implements the decoders for the four encoder 
modes presented hereinabove. This programmable composite decoder comprises a decoder 110 for parallel concate- 
nated codes, a threshold decision device 112 for implementing a decision rule, a decoder 114 for an outer code, and 
six switches S1 -S6. Assuming that the output of decoder 110 is the probability that the value of the decoded bit equals 
zero, an exemplary decision rule is: If the output is greater than 1/2, then decide that the decoded bit is zero; if less 
than 1/2, then assign the value one; if equal to 1/2, then arbitrarily assign a value. 

Decoder 110 for parallel concatenated codes further comprises a composite codeword to component codeword 
converter 116, N component decoders, N-1 interleavers and two identical deinterleavers 118. Each deinterleaver has 
a reordering function that returns a sequence of data elements that have been permuted by the N-1 interleavers con- 
nected in series to their original order. Table II as follows summarizes the switch positions for various modes of decoder 
operation. (In the table, X denotes the "don't care" condition, i.e., the switch may be in either position.) 
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Table II 



Mode 


Switch Positions 




S1 


S2 


S3 


S4 


S5 


S6 


(1) PCC 


0 


0 


CLOSED 


0 


0 


X 


(2) Serial concatenation with inner 
PCC 


0 


0 


CLOSED 


0 


0 


0 tor hard-decision decoding; 1 for 
soft-decision decoding 


(3) Standard serial concatenation 


1 


1 


OPEN 


1 


1 


0 for hard-decision decoding; 1 for 
soft-decision decoding 


(4) Single code 


1 


1 


OPEN 


1 


1 


X 



10 



15 



20 



25 



30 



35 



45 



50 



55 



The VSAT's utilize different codes (e.g., PCCC, tail-biting PCCC, recursive systematic convolutional, nonrecursive 
systematic convolutional, block codes) in different combinations (e.g., modes 1, 2, 3, and 4), depending on the com- 
munication application and required transmission rates. 

When convolutional codes are utilized in any of the modes described hereinabove, the programmable encoder of 
FIG. 3 may also include puncturing via a known pattern to increase the rate of the resulting code, and the programmable 
decoder of FIG. 4 may also include the associated depuncturing function. When punctured convolutional codes are 
used as the component codes in parallel concatenated coding, the codeword formatter of FIG. 3 deletes code bits from 
the component codewords according to the desired puncturing patterns. In this case, the PCC decoder's composite 
codeword to component codeword converter inserts neutral values for the punctured bits in the component codewords 
that it outputs to the component decoders. Note that in Mode 3 or Mode 4, encoder switches S4 and S5 and decoder 
switches S1 and S2 are all set to position 0. Therefore, FIGs. 3 and 4 show puncturing unit 140 and depuncturing unit 
142, respectively, in phantom for implementing these puncturing and depuncturing functions, respectively, when a 
punctured convolutional code is used in Mode 3 or Mode 4. 

In a preferred embodiment of this invention, convolutional codes are used as the component codes in an inner 
parallel concatenated code, and a block code (e.g., a Reed-Solomon code or BCH code) is used as an outer code in 
serial concatenation. 

In a preferred embodiment in which spread spectrum signals are transmitted by the VSATs, a random channel 
access protocol such as ALOHA is used in conjunction with code division multiple access. The hub receiver utilizes a 
number of demodulators for each spreading code in order to receive time-overlapping signals that utilize time-delayed 
versions of the same spreading sequence. Each demodulator for a given spreading sequence demodulates a signal 
using a different time shift of that spreading sequence. 

Also in a preferred embodiment, one or more spreading sequences are reserved for use by VSATs over specified 
periods of time on an assigned basis in order to provide higher-quality channels with greater throughput. Reservation 
requests from the VSAT's and assignments are processed by a network controller that is connected to a hub terminal. 

In a preferred embodiment that utilizes spread spectrum signals and the programmable encoder and decoder 
described hereinabove, the system associates a given spreading sequence with a particular error correcting code to 
allow different signals to utilize different error correcting codes simultaneously. Since each detected signal's spreading 
sequence is identified by a corresponding demodulator, the receiver can appropriately configure the programmable 
decoder for each detected signal. This mode of network operation is useful for simultaneously supporting several 
applications having different error correction coding requirements without the need for additional control signaling. 

A circular MAP decoder useful as the component decoders in FIG. 4 is described in commonly assigned, copending 
U.S. Patent Application No. 08/636,742. The circular MAP decoder can deliver both an estimate of the encoded data 
block and reliability information to a data sink, e.g., a speech synthesis signal processor for use in transmission error 
concealment or protocol processor for packet data as a measure of block error probability for use in repeat request 
decisions. As described in commonly assigned, copending U.S. Patent Application No. 08/636,732 of Stephen M. 
Hladik and John B. Anderson, filed April 1 9, 1 996, the circular MAP decoder is useful for decoding tail-biting convolu- 
tional codes, particularly when they are used as component codes in a parallel concatenated coding scheme. 

A circular MAP decoder for error-correcting trellis codes that employ tail biting according to U.S. Patent Application 
No. 08/636,742 produces soft -decision outputs. The circular MAP decoder provides an estimate of the probabilities of 
the states in the first stage of the trellis, which probabilities replace the a priori knowledge of the starting state in a 
conventional MAP decoder. The circular MAP decoder provides the initial state probability distribution in either of two 
ways. The first involves a solution to an eigenvalue problem for which the resulting eigenvector is the desired initial 
state probability distribution; with knowledge of the starting state, the circular MAP decoder performs the rest of the 
decoding according to the conventional MAP decoding algorithm. The second is based on a recursion for which the 
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iterations converge to a starting state distribution. After sufficient iterations, a state on the circular sequence of states 
is known with high probability, and the circular MAP decoder performs the rest of the decoding according to the con- 
ventional MAP decoding algorithm which is set forth in "Optimal Decoding of Linear Codes for Minimizing Symbol Error 
Rate," by Bahl, Cocke, Jelinek and Raviv, IEEE Transactions on Information Theory, pp. 284-287, March 1974. 
5 The objective of the conventional MAP decoding algorithm is to find the conditional probabilities: 

Pfstate m at time t/ receive channel outputs y p ... f yj . The term L in this expression represents the length of the 
data block in units of the number of encoder symbols. (The encoder for an (n, k) code operates on k-bit input symbols 
to generate n-bit output symbols.) The term y t is the channel output (symbol) at time r. 
The MAP decoding algorithm actually first finds the probabilities: 

10 

k t (m)=P{S t =m;Y t ;}; (1) 

that is, the joint probability that the encoder state at time i, -S t is m and the set of channel outputs = {y 1 yj is 

is received. These are the desired probabilities multiplied by a constant (P{V^}, the probability of receiving the set of 
channel outputs {yp-.^yj). 

Now define the elements of a matrix r, by 



20 T t (i,j) = Pfstate j at time f ; y t I state i at time t-1.} 

The matrix r, is calculated as a function of the channel transition probability R(Y P X), the probability p/m/m') that the 
encoder makes a transition from state m'to m at time t, and the probability q/X/m',m) that the encoder's output symbol 
is X given that the previous encoder state is m'and the present encoder state is m. In particular, each element of r, is 
25 calculated by summing over all possible encoder outputs Xas follows: 



~ (2) 
Yjm'/n) = 2*p t (mfm') q t (Xlm\m) R(Y (t X) . 

30 X. 

The MAP decoder calculates L of these matrices, one for each trellis stage. They are formed from the received channel 
output symbols and the nature of the trellis branches for a given code. 
Next define the M joint probability elements of a row vector a, by 



35 



40 



45 



50 



55 



otfM = Pfstate j at time t; y v ...,y t ] (3) 
and the ^conditional probability elements of a column vector p, by 

PrW = Pfruv -yt, ^tate j at time t) (4) 

for j = 0, 1,... t (M-1) where M is the number of encoder states. (Note that matrices and vectors are denoted herein by 
using boldface type.) 

The steps of the MAP decoding algorithm are as follows: 

(i) Calculate a,,..., a L by the forward recursion: 

a,= a M r,, f=7,...,L (5) 

(ii) Calculate (J,,..., P L ., by the backward recursion: 

Pi= r *,P*r t = L ' 1 (6) 
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(iii) Calculate the elements of X, by: 

Vtf = *fl) M' all i,t=1 L . (7) 

(iv) Find related quantities as needed. For example, let Af ( be the set of states Sp {Sj, S^, .... S*^} such that the 
I th element of Sp Sj is equal to zero. For a conventional non-recursive trellis code, SJ = dj, the j th data bit at time 
t. Therefore, the decoder's soft-decision output is 

p{ <= oiyL i } s jhz~x I x t (m) 

where 



m 

and 

m is the index that corresponds to a state S t . 

The decoder's hard-decision or decoded bit output is obtained by applying P{o\ 

That is, if P{o\ = 0/V^>£, then o\ = O, if P{o\ = 0/)r\}<±, then o\ = 1\ otherwise, arbitrarily assign c? f the value 0 or 1. 
As another example of a related quantity for step (iv) hereinabove, the matrix of probabilities ^comprises elements 
defined as follows: 

° t (U) = P{S M = i; S t = j; V^} = a,., (i) y t (i,j) p, (j) 

These probabilities are useful when it is desired to determine the a posteriori probability of the encoder output bits. 
These probabilities are also useful in the decoding of recursive convolutional codes. 

In the standard application of the MAP decoding algorithm, the forward recursion is initialized by the vector a 0 = 
(1,0,.. ..0), and the backward recursion is initialized by p t = (1,0,. ..0) T . These initial conditions are based on assumptions 
that the encoder's initial state S 0 = Oand its ending state S L = 0. 

One embodiment of the circular MAP decoder determines the initial state probability distribution by solving an 
eigenvalue problem as follows. Let a,, p,, r f and X t be as before, but take the initial a 0 and p L as follows: 

Set P L to the column vector ( 1 1 1 . . . 1 ) T . 

Let ocq be an unknown (vector) variable. 

Then, 

(i) Calculate r,for t = 7, 2,... L according to equation (2). 



= OPf\ } to the following decision rule: 
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(ii) Find the largest eigenvalue of the matrix product r 1 T 2 ... r L . Normalize the corresponding eigenvector so that 
its components sum to unity. This vector is the solution for a a The eigenvalue is 



(iii) Form the succeeding a, by the forward recursion set forth in equation (5). 

(iv) Starting from p t , initialized as above, form the p f by the backward recursion set forth in equation (6). 

(v) Form the X t as in (7), as well as other desired variables, such as, for example, the soft-decision output P/dj 

or the matrix of probabilities o> described hereinabove. 

The unknown variable a 0 satisfies the matrix equation 



"o 



*o r i r 2 - r L 



Based on the fact that this formula expresses a relationship among probabilities, the product of r f matrices on the right 
has largest eigenvalue equal to 



and that the corresponding eigenvector must be a probability vector. 

With the initial p L = (111... 1) T , equation (6) gives p L _ r . Thus, repeated applications of this backward recursion give 
all the $ t Once a 0 is known and P L is set, all computations in the circular MAP decoder follow the conventional MAP 
decoding algorithm. 

An alternative embodiment of the circular MAP decoder determines the state probability distributions by a recursion 
method. In particular, in one embodiment (the dynamic convergence method), the recursion continues until decoder 
convergence is detected . In this recursion (or dynamic convergence) method, steps (ii) and (iii) of the eigenvector 
method described hereinabove are replaced as follows: 

. (ii.a) Starting with an initial a 0 equal to (1/M,... t 1/M), where Mis the number of states in the trellis, calculate the 
forward recursion L times. Normalize the results so that the elements of each new a, sum to unity. Retain all L a t 
vectors. 

(ii.b) Let a 0 equal a L from the previous step and, starting at t = 7, calculate the first L Wmln a, probability vectors again. 
That is, calculate 



for m = 0, 1, M-1 and t = 1,2,...,L Wmin where L Wmln is a suitable minimum number of trellis stages. Normalize as 
before. Retain only the most recent set of L a's found by the recursion in steps (ii.a) and (ii.b) and the 0 ^ found 
previously in step (ii.a). 

(ii.c) Compare from step (ii.b) to the previously found set from step (ii.a). If the M corresponding elements of 
the new and old ^ are within a tolerance range, proceed to step (iv) set forth hereinabove. Otherwise, continue 
to step (ii.d). 
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(ii.d) Let t = t + 1 and calculate a,= a M r r Normalize as before. Retain only the most recent set of L a's calculated 
and the a, found previously in step (ii.a). 

(ii.e) Compare the new a/s to the previously found set. If the M new and old a/s are within a tolerance range, 
s proceed to step (iv). Otherwise, continue with step (ii.d) if the two most recent vectors do not agree to within the 

tolerance range and if the number of recursions does not exceed a specified maximum (typically 2L); proceeding 
to step (iv) otherwise. 

This method then continues with steps (iv) and (v) given hereinabove with respect to the eigenvector method to 
10 produce the soft-decision outputs and decoded output bits of the circular MAP decoder. 

In another alternative embodiment of the circular MAP decoder described in U.S. Patent Application No. 
08/636,742, the recursion method is modified so that the decoder only needs to process a predetermined, fixed number 
of trellis stages for a second time, that is, a predetermined wrap depth. This is advantageous for implementation pur- 
poses because the number of computations required for decoding is the same for every encoded message block. 
*5 Consequently, hardware and software complexities are reduced. 

One way to estimate the required wrap depth for MAP decoding of a tail-biting convolutional code is to determine 
it from hardware or software experimentation, requiring that a circular MAP decoder with a variable wrap depth be 
implemented and experiments be conducted to measure the decoded bit error rate versus E^N 0 for successively 
increasing wrap depths. The minimum decoder wrap depth that provides the minimum probability of decoded bit error 
20 for a specified Eb/N 0 is found when further increases in wrap depth do not decrease the error probability. 

If a decoded bit error rate that is greater than the minimum achievable at a specified Ei/N 0 is tolerable, it is possible 
to reduce the required number of trellis stages processed by the circular MAP decoder. In particular, the wrap depth 
search described hereinabove may simply be terminated when the desired average probability of bit error is obtained. 

Another way to determine the wrap depth for a given code is by using the code's distance properties. To this end, 
25 it is necessary to define two distinct decoder decision depths. As used herein, the term "correct path" refers to the 
sequence of states or a path through the trellis that results from encoding a block of data bits. The term "incorrect 
subset of a node" refers to the set of all incorrect (trellis) branches out of a correct path node and their descendants. 
Both the decision depths defined below depend on the convolutional encoder. 

The decision depths are defined as follows: 

30 

(i) Define the forward decision depth for ©-error correction, LF(e) , to be the first depth in the trellis at which all 
paths in the incorrect subset of a correct path initial node, whether later merging to the correct path or not, lie more 
than a Hamming distance 2e from the correct path. The significance of LF(e) is that if there are e or fewer errors 
forward of the initial node, and encoding is known to have begun there, then the decoder must decode correctly. 

35 a formal tabulation of forward decision depths for convolutional codes was provided by J.B. Anderson and K. 

Balachandran in "Decision Depths of Convolutional Codes", IEEE Transactions on Information Theory, vol. IT-35, 
pp. 455-59, March 1 989. A number of properties of LF(e) are disclosed in this reference and also by J.B. Anderson 
and S. Mohan in Source and Channel Coding - An Algorithmic Approach, Kluwer Academic Publishers, Norwell, 
MA, 1 991 . Chief among these properties is that a simple linear relation exists between /.Fand e; for example, with 

to rate 1/2 codes, LF is approximately 9.08e . 

(ii) Next define the unmerged decision depth for e-error correction, LU(e) , to be the first depth in the trellis at which 
all paths in the trellis that never touch the correct path lie more than a Hamming distance of 2e away from the 
correct path. 

45 

The significance of LU(e) for soft-decision circular MAP decoding is that the probability of identifying a state on 
the actual transmitted path is high after the decoder processes LU(e) trellis stages. Therefore, the minimum wrap depth 
for circular MAP decoding is LU(e). Calculations of the depth LU(e) show that it is always larger than LF(e) but that it 
obeys the same approximate law. This implies that the minimum wrap depth can be estimated as the forward decision 
50 depth LF(e) if the unmerged decision depth of a code is not known. 

By finding the minimum unmerged decision depth for a given encoder, we find the fewest number of trellis stages 
that must be processed by a practical circular decoder that generates soft-decision outputs. An algorithm to find LF 
(e), the forward decision depth, was given by J.B. Anderson and K. Balachandran in "Decision Depths of Convolutional 
Codes", cited hereinabove. To find LU(e): 

ss 

(i) Extend the code trellis from left to right, starting from ail trellis nodes simultaneously, except for the zero-state. 

(ii) At each level, delete any paths that merge to the correct (all-zero) path; do not extend any paths out of the 
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correct (zero) state node. 

(iii) At level k, find the least Hamming distance, or weight, among paths terminating at nodes at this level. 

5 (iv) If this least distance exceeds 2e, stop. Then, LU(e) = k. 

As described in U.S. Patent Application No. 08/636,742, experimentation via computer simulation lead to two 
unexpected results: (1) wrapped processing of p, improves decoder performance; and (2) the use of a wrap depth of 
LU(e) + LF(e) = 2 LF(e) improves performance significantly. Hence, a preferred embodiment of the circular MAP decoder 
10 algorithm based on recursion comprises the following steps: 

(i) Calculate r,for r = 1, 2, ... L according to equation (2). 

(ii) Starting with an initial a 0 equal to (1/M,..., 1/M), where M is the number of states in the trellis, calculate the 
15 forward recursion of equation (5) (L + L w ) times for u= 1, 2, ... (L + L w ) where L w \s the decoder's wrap depth. The 

trellis-level index r takes on the values ((u-1) modL) + 1. When the decoder wraps around the received sequence 
of symbols from the channel, a L is treated as a a Normalize the results so that the elements of each new <x f sum 
to unity. Retain the L most recent a vectors found via this recursion. 

20 (jjj) Starting with an initial p L equal to ( f,..., 1) T , calculate the backward recursion of equation (6) (L + L w ) times for 

u- 1, 2, ... (L + L w ). The trellis-level index t takes on the values L-(u mod L). When the decoder wraps around the 
received sequence, p, is used as p L+7 and Tj is used as r L+J when calculating the new p L . Normalize the results 
so that the elements of each new p, sum to unity. Again, retain the L most recent p vectors found via this recursion. 

2S The next step of this recursion method is the same as step (v) set forth hereinabove with respect to the eigenvector 

method to produce the soft-decisions and decoded bits output by the circular MAP decoder. 



Claims 

30 

1. A VSAT communications system for communication via satellite, comprising: 

a plurality of VSAT terminals each comprising: 

35 a parallel concatenated encoder comprising a plurality of component encoders connected in a parallel con- 

catenation, the parallel concatenated encoder applying a parallel concatenated code to a block of data bits 
received from a source and generating component codewords therefrom, the parallel concatenated encoder 
comprising a codeword formatter for formatting the bits of the component codewords to provide a composite 
codeword; 

40 

a packet formatter for assembling data packets for transmission, each data packet comprising bits from at 
least one composite codeword; 

a modulator for receiving the data packets and providing modulated signals therefrom; 

45 

an up-converter for translating modulated signals to a carrier frequency; 

an interface for connecting each respective VSAT terminal to an antenna for transmitting modulated signals 
to the satellite and receiving modulated signals from the satellite: 

50 

a down-converter for translating each received signal from the carrier frequency to an intermediate frequency; 

a demodulator for synchronizing to and demodulating the received signals; 

55 a packet-to-codeword formatter for forming received composite codewords from the demodulated signals; and 

a composite decoder comprising a plurality of component decoders for decoding the received composite code- 
words. 
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2. The communications system of claim 1 wherein the component encoders comprising the parallel concatenated 
encoder apply convolutional codes to the block of data bits. 

3. The communications system of claim 2 wherein the parallel concatenated convolutional code comprises recursive 
systematic codes. 

4. The communications system of claim 2 wherein the parallel concatenated convolutional code comprises tail-biting 
nonrecursive systematic codes. 

5. The communications system of claim 4 wherein the component decoders comprise circular MAP decoders. 

6. The communications system of claim 1 wherein the modulator comprises a spread spectrum modulator, and the 
demodulator comprises a despreading demodulator. 

7. The communications system of claim 1 wherein: 

the parallel concatenated code comprises an inner parallel concatenated code connected in series concate- 
nation with an outer code; and 

the decoder comprises an inner decoder associated with the inner parallel concatenated code and further 
comprises an outer decoder associated with the outer series concatenated code. 

8. The communications system of claim I wherein the encoder and decoder comprise a programmable encoder/ 
decoder system comprising a plurality of coding options selectable via switches. 

9. The communications system of claim 8 comprising four coding/decoding options: 

(1) parallel concatenated coding; 

(2) an outer code in series concatenation with an inner parallel concatenated code; 

(3) serial concatenated coding comprising an outer encoder and an inner single component encoder; and 

(4) single code such that only one component encoder is utilized. 

10. The communications system of claim 8, further comprising at least one hub terminal; 

the modulator of each VSAT terminal comprising a spread spectrum modulator for applying one of a plurality 
of spreading sequences to each data packet to be transmitted, the spreading sequences being grouped into 
sets, each set comprising at least one spreading sequence, each set of spreading sequences being associated 
with one of the coding options; 

the hub terminal comprising at least one despreading demodulator for each spreading sequence and a plurality 
of decoders, said hub terminal demodulating and decoding signals received from the satellite which are trans- 
mitted in time-overlapping intervals and which signals each utilize one of the coding options and one of the 
spreading sequences associated therewith, the decoders being configured for each received signal based on 
the spreading sequence identified by the despreading demodulator. 

11. The communications system of claim 1 , further comprising at least one hub terminal for providing star connectivity. 

12. The communications system of claim 1 wherein the parallel concatenated encoder further comprises a puncturing 
function for deleting code bits from the component codewords according to a predetermined puncturing pattern, 
and the composite decoder comprises a depuncturing function for inserting neutral values for the punctured bits 
in the component codewords. 
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